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SECTION 1 

GENERAL DESCRIPTION 



The NCR SCSI Protocol Controller (SPC) is designed to accomodate the Small Computer Systems 
Interface (SCSI) as defined by the ANSI X3T9.2 committee. The SPC operates in both the Initiator and 
Target roles and can therefore be used in host adapter and control unit designs. This device supports 
arbitration, including reselection, and is intended to be used in systems that require either open collector 
or differential pair transceivers. 

The NCR 5385E SCSI Protocol Controller communicates with the system microprocessor as a 
peripheral device. The chip is controlled by reading and writing several internal registers which may be 
addressed as standard or memory mapped I/O. A 24-bit Transfer Counter and the appropriate handshake 
signals accommodate large DMA transfers with minimal processor intervention. Since the NCR 5385E 
interrupts the MPU when it detects a bus condition that requires servicing, the MPU is freed from polling 
or controlling any of the SCSI bus signals. 



Below is a list of important features: 

SCSI INTERFACE 

*Supports ANSI X3T9.2 SCSI Standard 

- Asynchronous data transfers to 1.5 MBPS 

- Supports both Initiator and Target roles 

- Parity generation with optional checking 

- Supports arbitration 

- Controls all bus signals except Reset 
• Doubly-buffered Data Register 



MPU INTERFACE 

*Versatile MPU Bus Interface 

- Memory or I/O mapped MPU interface 

- DMA or programmed I/O transfers 

- 24-bit Internal Transfer Counter 

- Programmable (Re)Selection timeouts 

- Interrupts MPU on all bus conditions 
requiring service 
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FIG. 1.1 FUNCTIONAL PIN GROUPING 
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SECTION 2 

PIN DESCRIPTION 
2.1 MICROPROCESSOR INTERFACE SIGNALS 



CLK 


16 


RESET 


4 


D0-D7 


3-1 




47-43 


INT 


19 


WR 


30 


RD 


31 


CS 


21 


A0-A3 


22, 23, 25 


DREQ 


29 



DACK 



Symmetrical square wave signal which generates internal chip timing. 
Maximum frequency is 10 MHz. 

When high (1), this signal forces the chip into a reset state. All current 
operations are terminated. Internal storage elements are cleared and 
self-diagnostics are performed. 

These signals comprise an active high data bus. It is intended that these 
signals be connected to the microprocessor data bus. 

This signal is used to interrupt the microprocessor for various bus 
conditions that require service. INT is set high for request and cleared 
when the chip is reset or the Interrupt Register is read. 

Write pulse (active low) is used to strobe data from the data bus into an 
internal register which has been selected. 

Read pulse (active low) is used to read data from an internal register 
that has been selected. The contents of the register is strobed onto 
the data bus. 

When low (0), this signal enables reading from or writing to the internal 
registerwhich has been selected. 

22, 23, 25, 26 These signals are used in conjunction with CS , to address all the 
internal registers. 

Data request. When high (1), this signal indicates that the internal Data 
Register has a byte to transfer (inputting from the SCSI bus) or needs a 
byte to transfer (outputting to the SCSI bus). This signal becomes 
active only if the DM A mode bit in theCommand Register is on. It is 
cleared when DACK becomes active. 

27 Data acknowledge. When low (0), th is sign al resets DREQ and selects 

the Data Register for input or output. DAC K acts as a dhip select for the 
Data Register when in the DMA mode. DACK and CS must never be 
active at the same time. 



2.2 SCSI INTERFACE SIGNALS 



ID0-ID2 



SB0-SB7, SBP 


34-41, 


BSYIN 


17 


BSYOUT 


42 


SELIN 


18 


SELOUT 


32 


ATN 


5 



ACK 



REQ 



MSG, C/D, I/O 



IGS 



14-12 These active low signals determine the three-bit code of the SCSI bus 
ID assigned to the chip. External pullup resistors are required only if 
tied to switches or straps. 

34-41 , 33 Active high data bus. These signals comprise the SCSI data bus and are 
intended to be connected to the external SCSI bus transceivers. 

When high (1), this signal indicates to the chip that the SCSI BSY signal 
is active. 

When high (1), the chip is asserting the BSY signal to the SCSI bus. 

When high (1), this signal indicates to the chip that the SCSI SEL signal 
is active. 

When high (1), the chip is asserting the SEL signal to the SCSI bus. 

INITIATOR ROLE: The chip asserts this signal when the microprocessor 
requests the attention condition or a parity error has been detected in 
a byte received from the SCSI bus. 

TARGET ROLE: This signal is an input which indicates the state of the 
ATN signal on the SCSI bus. 

INITIATOR ROLE: The chip asserts this signal in response to REQ for 
a byte transfer on the SCSI bus. 

TARGET ROLE: This signal is an input which, when active, indicates a 
response to the REQ signal. 

INITIATOR ROLE: This signal is an input which, when active, indicates 
that the Target is requesting a byte transfer on the SCSI bus. 
TARGET ROLE: Asserted by the chip to request a byte transfer on the 
SCSI bus. 

INITIATOR ROLE: These signals are inputs which indicate the current 
SCSI bus phase. 

TARGET ROLE: The chip drives these signals to indicate the current 
bus phase. 

Initiator Group Select. When high (1), this signal indicates to the external 
SCSI drivers that the chip is controlling in the Initiator role. Its purpose 
is to enable the external drivers for ATN and ACK. 
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11 



9,8,7 



TGS 



28 Target Group Select. When high (1), this signal indicates to the external 

SCSI drivers that the chip is controlling in the Target role. Its purpose 
is to enable the external drivers for REQ, MSG, C/D, and I/O. 



SBEN 20 SCSI data Bus Enable. When low (0), this signal directly enables the 

external SCSI data bus drivers. 

ARB 15 Arbitration phase. When high (1), this signal enables the external 

circuitry to place the ID bit on the SCSI bus for the Arbitration phase. 



POWER SIGNALS 

VCC 48 +5 V input 

GND 24 Signal reference input 



SECTION 3 

ELECTRICAL CHARACTERISTICS 



PARAMETER 


OPERATING CONDITIONS 

SYMBOL MIN 


MAX 


UNITS 


Supply Voltage 
Supply Current 
Ambient Temp. 


vdd 

'DD 

ta 


4.75 



5.25 
300 
70 


Vdc 
mA 
°C 



PARAMETER 



INPUT SIGNAL REQUIREMENTS 

CONDITIONS MIN 



MAX 



UNITS 



High-level Input, Vih 




2.0 


5.25 


Vdc 


Low-level Input, V||_ 




-0.3 


0.8 


Vdc 


High-level Input Current, l|H 


V|H = 5.25V 




10 


M 


Low-level Input Current, l|i_ 


V|L = 0V 




-10 


/|A 



OUTPUT SIGNAL REQUIREMENTS (Except SBEN , IGS, and TGS) 

PARAMETER CONDITIONS MIN MAX 



High-level Output Voltage, VfjH 


V D D = 4.75V® 
IOH= -400 juA 


2.4 


— 


Vdc 


Low-level Output Voltage, Vql 


Vdd = 4.75V® 
|QL= 2.0mA 


— 


0.4 


Vdc 



SBEN , IGS, and TGS SIGNALS 



PARAMETER 



CONDITIONS 



MIN 



MAX 



UNITS 



High-level Output Voltage, VfjH 
Low-level Output Voltage, Vql 


Vdd = 4.75V® 
IOH = -400^A 
Vdd = 4.75V® 
|QL= 4.0mA 


2.4 


0.4 


Vdc 
Vdc 



PRELIMINARY 

Notice: This is not a final specification. 
Some parametric limits are subject to change. 



SECTION 4 

INTERNAL REGISTERS 



4.0 GENERAL 

The NCR SCSI Protocol Controller has a set of internal registers which are used by the microprocessor 
to direct the operation of the SCSI_bus._Th ese registers are read (written) by activating CS with an ad- 
dress on A3-A0 and then issuing a RD/(WR) pulse. They can be made to appear to a microprocessor as 
standard I/O ports or as memory-mapped I/O ports depending on the external circuitry that controls 
CS. The following sections describe the operation of these internal registers. 

REGISTER SUMMARY 



A3 A2 A1 A0 R/W 



REGISTER NAME 















R/W 


Data Register 











1 


R/W 


Command Register 








1 





R/W 


Control Register 








1 


1 


R/W 


Destination ID 













R 


Auxiliary Status 










1 


R 


ID Register 







1 





R 


Interrupt Register 







1 


1 


R 


Source ID 










1 


R 


Diagnostic Status 












R/W 


Transfer Counter (MSB) 









1 


R/W 


Transfer Counter (2nd BYTE) 






1 





R/W 


Transfer Counter (LSB) 






1 


1 


R/W 


Reserved for Testability 



4.1 DATA REGISTER 

The Data Register is used to transfer SCSI commands, data, status and message bytes between the 
microprocessor data bus and the SCSI bus. This is an eight-bit register which is doubly-buffered in order 
to support maximum throughput. In the non-DMA mode, the microprocessor reads from (writes to) the 
Data Register by activating CS with A3-A0 = 0000 and issuing a RD/(WR) pulse. A bit has been included 
in the Auxiliary Status Register to indicate when the Data Register is full . In the DMA mode, the DMA 
logic reads from (writes to) the Data Register by responding to DREQ with DACK and issuing a RD/(WR) 
pulse. The SCSI bus reads from or writes to the Data Register when the chip is connected as an Initiator 
or Target and the bus is in one of the Information Transfer Phases. 



4.2 COMMAND REGISTER 

The Command Register is an eight-bit register used to give commands to the SCSI chip. The micro- 
processo r ca n write to (read from) the Command Register by activating CS with A3-A0 = 0001 and 
issuing a WR/(RD) pulse. Writing to the Command Register causes the chip to execute the command 
that is written. The Command Register can be read; however, the chip resets the Command Register 
when it sets an Interrupt. Therefore, one cannot guarantee that the data in the register will be correct 
after loading an interrupting command or enabling selection or reselection. To be safe, a copy of the 
last command issued should be stored in the microprocessor's memory. Immediate commands are not 
stored. 

The contents of the Command Register are described in a later section (See page 19, COMMANDS). 



4.3 CONTROL REGISTER 

This eight-bit read/write register is used for enabling certain modes of operation for the SCSI Protocol 
Controller. The microprocessor reads from (writes to) the Control Register by activating CS with A3-A0 
= 0010 and issuing a RD (WR) pulse. 



7 


6 


5 


4 


3 


4 
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L 













Select Enable 
Reselect Enable 
Parity Enable 



BIT 7-3 Reserved 

BIT 2 Parity Enable 

BIT 1 Reselect Enable 

BIT Select Enable 



When the parity enable bit is a "1", the chip generates and 
checks parity on all transfers on the SCSI bus. When the 
parity enable bit is a "0", the chip generates but does not check 
parity on bus transfers. 

When this bit is a "1", the chip will respond to any attempt by 
aTargetto reselect it. When the bit is a "0", the chip will ignore 
all attempts to reselect it. 

When this bit is a "1", the chip will respond to attempt to select 
it as a Target. When it is a "0", the chip will ignore all selections. 



NOTE: After being reset and completing self-diagnostics, the control register will contain all zeros. 



10 



4.4 DESTINATION ID REGISTER 

The Destination ID Register is an eight-bit register that is used to program the SCSI bus address of the 
destination device prior to issuing a Select or Reselect command to the chip. Bits 0-2 specify the address 
and bits 3-7 are always zeroes. The ID register is written (read) by activating CS with A3-A0 equal to 
"0011" and then pulsing WR(RD). 



7 6 5 4 3 2 10 



-Destination ID 



4.5 AUXILIARY STATUS REGISTER 

The Auxiliary Status Register is an eight-bit read-only register. It contains bits which indicate the status 
of the chip's operational condition. Some of these bits are used to determine the reason for interrupts. 
Therefore, the Auxiliary Status Register should always be read prior to reading the Interrupt Register 
when servicing interrupts. After the Interrupt Register is read, the Auxiliary Status Register bits needed 
to service the interrupt may change. 

The Auxiliary Status Register is read by activating CS with A3-A0 = 0100 and then pulsing RD. The 
individual bits of the Auxiliary Status Register are defined below. 



7 6 5 4 3 2 10 



Not Used 

-Transfer Counter Zero 
-Paused 
-I/O 
-C/D 
-MSG 

-Parity Error 
-Data Register Full 
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BIT 7 Data Register Full 



BIT 6 Parity Error 



BIT 3-5 I/O, C/D, MSG 



This bit indicates the status of the Data Register and must be 
monitored by the microprocessor during non-DMA mode com- 
mands that use the Data Register. When the DMA mode bit in the 
Command Register is off (0) and the command being executed is 
one of Send, Receive or Transfer Info commands (refer to Section 
5.0 page 19, COMMANDS), data is transferred to (from) the chip 
by writing (reading) the Data Register. Data Register Full is set 
on (1) when data is written and turned off (0) when data is read. 
Therefore, Data Register Full should be on before taking data 
from the chip, and off when sending data to the chip. 

The Data Register Full bit is always reset (to 0) at the time an 
interrupting type command is loaded into the Command 
Register. Therefore, when issuing such commands, the Com- 
mand Register should be loaded prior to loading the Data 
Register and monitoring the Data Register Full flag. 

When this bit is one, it indicates that the chip has detected a 
parity error on a byte of data received across the SCSI bus. It 
can be set when the chip is executing one of the Receive 
commands or the Transfer Info command (when the transfer is 
an input). This bit is reset after the Interrupt Register is read. 

These bits indicate the status of the SCSI I/O, C/D, and MSG 
signals at all times. They define the Information Phase type being 
requested by the Target. These signals are significant when 
servicing interrupts and the chip is logically connected to the 
bus in the Initiator role. An interrupt will occur with any phase 
change. This allows the Initiator to prepare for the next phase 
of data transfer. These bits are only held while INT is active. 
The bits are coded as follows: 



I/O 


C/D MSG 


BUS PHASE 











Data Out 








1 


Unspecified Info Out 





1 





Command 





1 


1 


Message Out 


1 








Data In 


1 





1 


Unspecified Info In 


1 


1 





Status 


1 


1 


1 


Message In 
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BIT 2 Paused 



BIT 1 Transfer Counter Zero 



BIT Not Used 



When on (1), this bit indicates that the chip has aborted the 
command being executed in response to the Pause command. 
It is turned off when the interrupting type command code is 
loaded into the Command Register. 

This bit is provided to indicate the status of the 24-bit Transfer 
Counter. When on (1), it indicates that the Transfer Counter is 
equal to zero. It is intended to facilitate interrupt servicing. 



NOTE: The Auxiliary Status Register will contain the following pattern after a Reset and self-diagnos- 
tics: OOxxxOIO. 

4.6 ID REGISTER 

The ID Register is an eight-bit read-only register that indicates the logical SCSI bus address occupied by 
the chip. Bit 0-2 directly reflect the logical inversion of the chip ID input signals ID0-ID2. The ID Register 
is active high whereas the ID input signals are active low. The ID Register allows the microprocessor to 
read the chip's SCSI bus address which would normally be strappedjn hardware. Bits 3-7 of the ID 
Register_will always be zeroes. The ID Register is read by activating CS with A3-A0 = 0101 and then 
pulsing RD. 
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Device ID 
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4.7 INTERRUPT REGISTER 

The Interrupt Register is an eight-bit read-only register. It is used in conjunction with the Auxiliary Status 
Register to determine the reason for an interrupt condition. This register is read by activating CS with 
A3-A0 = 0110 and then pulsing RD. When the Interrupt Register is read, it automatically resets itself 
(after the read is complete) and enables the chip for a new interrupt condition. Since the Parity Error 
bit in the Auxiliary Status Register is reset after a read of the Interrupt Register, and since I/O, C/D, and 
MSG are only held while INT is active, the Auxiliary Status Register should always be read prior to reading 
the Interrupt Register. 

If a Selected or Reselected interrupt occurs after issuing a command that would normally cause an 
interrupt, the chip will ignore the last command issued. This allows the microprocessor to service the 
Selected or Reselected interrupt prior to proceeding with the other operation. An example of this 
situation is when the microprocessor issues a command to select a Target at about the same time 
another Target reselects the chip. If the chip sees the reselection first, the microprocessor will receive 
an interrupt for the reselection, and the chip will ignore the Select command, which would now be invalid 
since the chip is now logically connected on the SCSI bus to another device. 

Individual interrupt conditions are described below. (Note: that for all cases, an interrupt condition is 
on, when the corresponding bit is a one (1), and off when zero (0).) 



7 6 5 4 3 2 10 



-Function Complete 
-Bus Service 
-Disconnected 
-Selected 
-Reselected 
-(Used for Testability) 
-Invalid Command 
-Not Used 
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BIT 7 Not Used 

BIT 6 Invalid Command 

BIT 5 Not Used 

BIT 4 Reselected * 



BIT 3 Selected * 



BIT 2 Disconnected 



BIT 1 Bus Service 



BIT Function Complete 



May be either (1) or (0). 

When on (1), this bit indicates that the last command loaded 
into the Command Register is not valid. 

(Reserved for testability) 

This interrupt will be on (1) when the chip has been reselected 
by another SCSI device. After setting this interrupt, the chip is 
logically connected to the bus in an Initiator role and is waiting 
for the Target to send REQ or disconnect from the bus. 

This interrupt will be on (1) whenever the chip has been selected 
by another SCSI device. 

After setting this interrupt, the chip is logically connected to 
the bus in the Target role and is waiting for a command to be 
loaded into the Command Register. 

'The chip will become selected (reselected) only if the ID data 
byte put on the SCSI bus during the Selection (Reselection) 
Phase has good parity and not more than one ID other than the 
chip's own ID is on. 

This interrupt will be set on (1) when the chip is connected to 
the bus in the Initiator role and the Target disconnects or when 
the chip is executing a Select or Reselect command and the 
destination device does not respond before the Transfer Counter 
times out. 

When the chip is logically connected to the bus in the Initiator 
role, this bit will be set on (1) whenever the Target sends a REQ 
which the chip cannot automatically handle. This happens when 
the first REQ for connection is received or when the chip is 
executing a Transfer Info or Transfer Pad command and either 
the Transfer Counter is zero or the Target changes the In- 
formation Phase type. 

A Bus Service interrupt may also be set if a phase change occurs 
before REQ is seen. This early notification will allow the Initiator 
extra time to prepare for a phase change in some unbuffered 
systems. (Note: that the chip may generate Bus Service 
Interrupts for phases that never request transfers. This is not 
an error condition, merely transitional status of I/O, C/D, and MSG.) 

If the chip is logically connected in the Target role, this bit 
will be set on (1) whenever the Initiator asserts ATN. When 
indicating ATN the Bus Service interrupt may occur by itself, 
with a Selected interrupt, or with a Function Complete interrupt. 

When this bit is on (1), it indicates that the last interrupting 
command has completed. It is the normal successful completion 
interrupt for Select, Reselect, Send and Receive commands 
(Refer to Section 5.0 page 19, COMMANDS). During any of the 
Receive commands, it is set on (1) along with the parity error 
bit as soon as a parity error is detected. A Bus Service Interrupt 
may also occur simultaneously with the Function Complete if 
an ATN signal was activated during a Send or a Receive command. 

The Function Complete interrupt is also generated at the end 
of a Message In phase for a Transfer Info command. (See 
TRANSFER INFO command, page 29 for details.) 
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4.8 SOURCE ID REGISTER 

The Source ID Register is an eight-bit read-only register which contains the three-bit encoded ID of the 
last device which Selected or Reselected the chip. The following is the format of the Source ID Register. 



7 6 5 4 3 2 10 



Source ID 
ID Valid 



The ID Valid bit indicates that the source device placed its own ID bit on the SCSI bus during the Selection 
Phase. The SPC chip has encoded the source ID and placed it in bits 2-0. This information remains 
valid until the chip disconnects from the SCSI bus, at this time the ID Valid bit is reset. 
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4.9 DIAGNOSTIC STATUS REGISTER 

The Diagnostic Status Register is an eight-bit read-only register which indicates the result of self- 
diagnostics and the last diagnostic command issued to the chip. The format of the Diagnostic Status 
Register is shown below. 



7 6 5 4 3 2 10 



Self-diagnostic Status 

000 Successful Completion 

001 Unconditional Branch Fail 

010 Data Reg. Full Failed 

011 Initial Conditions Incorrect 

100 Initial Command Bits Incorrect 

101 Diagnostic Flag Failed 

110 Data Turnaround Failed 

111 Not Used 

Diagnostic Command Status 



001 Turnaround Miscompare (Initial) 

010 Turnaround Miscompare (Final) 

011 Turnaround Good Parity 
100 Turnaround Bad Parity 

Self-Diagnostic Complete 



Bit 7 = 1 indicates that self-diagnostics have been completed. (NOTE: A reset will clear bits 6-3 if 
possible). After a reset to the chip, the microprocessor should make sure that the Diagnostic Status 
Register contains the following pattern before attempting any commands: 10000000. This code indicates 
self-diagnostics are complete and no errors were detected. After a diagnostic command has been 
executed, bits 6-3 will contain the resulting status, but bit 7 and bits 2-0 are not affected. 

The microprocessor may read the Diagnostic Status Register by activating CS with A3-A0 = 1001 and 
issuing aRD pulse. 

If an error is detected during self-diagnostics, the proper status is loaded into the Diagnostic Status 
Register and the chip halts until a Reset command or a Reset signal is asserted. Refer to the Self- 
Diagnostic Status Code Summary for an explanation of the individual codes. 

When a diagnostic command is issued to the chip, the chip will attempt to perform the function, load 
a status into bits 6-3, and initiate a Function Complete Interrupt. 
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4.9.1 SELF-DIAGNOSTIC STATUS CODE SUMMARY 

000 - Successful Completion. The chip executed all self-diagnostics following a reset and detected 

no errors. 

001 - Unconditional Branch Failed. The chip's internal sequencer attempted an unconditional 

branch and failed to reach the desired location. 

010 - Data Register Full Failed. The chip attempted to set and reset the Data Register Full status bit 

in the Interrupt Register and failed. 

011 - Initial Conditions Incorrect. The chip detected one of its internal initial conditions in the 

wrong state. 

100 - Initial Command Bits Incorrect. The chip tested bits 6,4,2,1 and of the Command Register 

and found at least one was not zero. 

101 - Diagnostic Flag Failed. The chip failed in its attempt to set and reset its internal diagnostic flag. 

110 - Data Turnaround Failed. During self-diagnostics the chip attempts to flush several bytes of 
data through its internal data paths. It also attempts to set and reset the Parity Error bit in the 
Interrupt Status Register. This status indicates that one of these operations failed. 



4.10 TRANSFER COUNTER (three eightbit counters) 

The Transfer Counter is comprised of three, eight-bit register/counters. It is used by the chip for Send, 
Receive and Transfer commands that require more than a single byte of data to be transferred. It may 
also be used with Select and Reselect commands to set a timeout for no response. To write to (read from) 
the Transfer Counter, CS is activated with A3-A0 selecting a byte and then pulsing WR (RD). The 
Transfer Counter is addressed as shown below. 



A3 A2 A1 A0 SELECTED BYTE 

110 Most Significant Byte 

110 1 Middle Byte 

1110 Least Significant Byte 



For Send, Receive and Transfer commands with single-byte not specified, the Transfer Counter specifies 
to the chip the maximum number of bytes to be sent or received before interrupting. The Transfer 
Counter must be loaded prior to issuing the command. When single-byte is specified, the chip neither 
uses nor alters the Transfer Counter. To facilitate servicing interrupts for commands that use the 
Transfer Counter, a bit is provided in the Auxiliary Status Register to indicate when the Transfer Counter 
is zero. 

For Select and Reselect commands, the Transfer Counter specifies the number of time intervals (1024 
CLK periods) that the chip will wait before automatically aborting the command due to no response 
(BSY) from the destination device. The Transfer Counter must be loaded prior to issuing the command. 
If the Transfer Counter is loaded with all zeroes, the timeout logic in the chip will be disabled, and the 
chip will not automatically abort the command due to no response. 
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SECTION 5 

COMMANDS 



This section defines command format, types, codes and operation. Commands are given to the chip by 
loading the Command Register. 

5.1 COMMAND FORMAT 

The bits in the Command Register are defined as follows. 
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01001 Select w/oATN 
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10100 Transfer Info 








10101 Transfer Pad 
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BIT 7 



DMA Mode 



BIT 6 Single Byte Transfer 



This bit is applicable only for commands that use the Data 
Register. When this bit is on (1), it indicates that data will be 
transferred to (fro m) the Data Register using the DMA signals 
DREQ and DACK. When it is off (0), the microprocessor must 
monitor the state of the Data Register Full flag in the Auxiliary 
Status Register. Data is then transferred by using the appropriate 
input/output command. 

When on (1), this bit indicates that only one byte of data is to be 
transferred for this command. The Transfer Counter will not be 
used or altered by the chip. Therefore, for common single byte 
message and status transfers, the Transfer Counter does not 
need to be loaded prior to issuing a command with this bit set. 
When this bit is off (0). the Transfer Counter is used by the chip 
to determine the length of the transfer for the command. 



BIT 5 Reserved 

BIT 4-0 Command Code 



This bit is not used and should always be programmed off (0). 
These bits are used to specify the command to be executed. 



5.2 COMMAND TYPES 

There are two types of commands; Immediate and Interrupting. All of the Immediate commands, except 
for Pause, cause immediate results within three clock cycles from the time the Command Register is 
loaded. The Pause command is explained in a later section (See page 22, PAUSE). Interrupting commands 
do not result in immediate action. Their completion is always flagged by an interrupt. 

Command codes 00000-00111 specify Immediate commands. Immediate commands that are listed as 
reserved, will be ignored if issued to the SPC chip. Command codes 01000-10101 specify Interrupting 
commands. When one of these codes is loaded into the Command Register, a second Interrupting com- 
mand code should not be loaded until after the interrupt has occurred for the first command. However, 
an Immediate type command may be loaded before the interrupt for an Interrupting command occurs. 
If a reserved Interrupting command code is issued, the chip will respond with an Invalid Command 
interrupt. 
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5.3 INVALID COMMANDS 

The user of the chip can be in one of three states at any particular time: Disconnected, connected as an 
Initiator, or connected as a Target. Commands are valid only in specified states. If an invalid Immediate 
command is issued, the chip will ignore the command. If an Interrupting command is issued in an invalid 
state, or a reserved Interrupting command code is issued, an Invalid Command interrupt will result. The 
exceptions are described below: 

The microprocessor must never issue any interrupting type command when the chip is not expecting 
such a command. Unpredictable results will occur in this case. The following is a list of user states in 
which the chip is not expecting an interrupting command: 

1. The chip is currently processing an Interrupting type command and has not yet set the interrupt to 
signal the completion. 

2. The chip is currently processing an Interrupting type command, a Pause command has been issued 
but the Paused bit in the Auxiliary Status Register has not been set. 

3. The chip is connected as an Initiator, but the Target has not yet requested an Information Transfer. 

4. The chip has completed a Transfer Info or Transfer Pad command and the Target has not requested 
additional information or has not changed the Information Phase. 

In user states three and four, described above, the microprocessor must wait for a Bus Service, Dis- 
connected, or Function Complete interrupt. 

If an interrupting command is illegitimately issued in these states, no interrupt will occur for it, and it is 
likely that the current function will be altered. 



5.4 COMMAND SUMMARY 

Below is a summary that lists all commands. In the table the following abbreviations are used. 

I = CONNECTED AS AN INITIATOR 



INT = INTERRUPTING 
IMM = IMMEDIATE 



D = DISCONNECTED 

T = CONNECTED AS A TARGET 



COMMAND CODE 


COMMAND 


00000 


Chip Reset 


00001 


Disconnect 


00010 


Paused 


00011 


Set ATN 


00100 


Message Accepted 


00101 


Chip Disable 


00110-00111 


Reserved 


01000 


Select w/ATN 


01001 


Select w/o ATN 


01010 


Reselect 


01011 


Diagnostic 


01100 


Receive Command 


01101 


Receive Data 


01110 


Receive Message Out 


01111 


Receive Unspecified Info Out 


10000 


Send Status 


10001 


Send Data 


10010 


Send Message In 


10011 


Send Unspecified Info In 


10100 


Transfer Info 


10101 


Transfer Pad 


10110-11111 


Reserved 



TYPE 


VALID STATES 


IMM 


D.I.T 


IMM 


l,T 


IMM 


D,T 


IMM 


I 


IMM 


I 


IMM 


D.l.T 


IMM 




INT 


D 


INT 


D 


INT 


D 


INT 


D 


INT 


T 


INT 


T 


INT 


T 


INT 


T 


INT 


T 


INT 


T 


INT 


T 


INT 


T 


INT 


I 


INT 


I 


INT 
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5.5 COMMAND DEFINITIONS 

5.5.1 CHIP RESET 

Chip Reset immediately stops any chip operation and resets all registers, counters, etc. on the chip. 
It performs the same operation as the hardware "reset" input. 

5.5.2 DISCONNECT 

Upon receipt of this command, the chip immediately releases all SCSI bus signals and returns to a 
Disconnected idle state. For the Target role, this is the normal method of disconnecting from the bus 
when a transfer is complete. For the Initiator role, Disconnect may be used to release the bus signals 
as a result of a timeout condition. In this case, the chip ignores the Target and is left in the Disconnected 
state. For the Disconnected state, it is not valid to issue a Disconnect command. If issued, the chip will 
ignore this command. 

5.5.3 PAUSE 

Pause is an Immediate command that is valid in the Disconnected state or when logically connected to 
the bus as a Target device. Pause is not valid when connected as an Initiator. 

When connected as a Target, the Pause command provides a means of halting a Send or Receive com- 
mand without having to wait for the transfer to complete. When Pause is issued, it immediately sets a 
flag in the chip. Within one byte transfer cycle, the chip recognizes the flag, aborts the Send or Receive 
operation, and then sets the Paused status bit in the Auxiliary Status Register. At this time, the chip is 
still connected to the bus in the Target role, and it is waiting for another command. 

The Pause command stops the Send or Receive command in an orderly manner leaving the Transfer 
Counter in a valid state that indicates the remaining number of bytes to be transferred. Also no REQ or 
ACK is asserted on the bus and no data is left in the chip waiting to be transferred. An operation that is 
paused may be resumed, if desired, simply by reloading the original command into the Command 
Register. (Note: after issuing the Pause while executing Send or Receive, it is necessary to continue 
transferring data with the chip (due to double-buffering) until the Paused status bit is set or an interrupt 
occurs.) 

When in the disconnected state, Pause may be issued to abort a Select or Reselect command. After a 
Select or Reselect command is issued and before an interrupt occurs, a Pause command may be issued 
to abort the operation. The Pause command immediately sets an internal flag. If the chip has not yet won 
arbitration, it sets the Paused bit in the Auxiliary Status Register and waits in the disconnected state for 
another command. If the chip has won arbitration, it releases the bus by dropping the two ID bits with 
SELOUT on for a minimum of 100>t/s, checks for no BSYIN, and then releases the bus. After this pro- 
cedure, it sets the Paused bit in the Auxiliary Status Register and waits for another command in the 
Disconnected state. 

Since Pause is an Immediate command, it does not cause an interrupt. As previously noted, the chip 
sets the Paused status bit to indicate that is has been executed. If an interrupt-causing event occurs 
before the chip sees the pause flag set, the chip will set the interrupt. In this case, the Paused status bit 
is not set by the chip either before or after the interrupt. In all cases, an interrupt-causing event will 
take precedence over Pause. For example, in the Target role if ATN is on when Pause is issued, a Bus 
Service interrupt will occur and the Paused status bit will not be set. 

If the Pause command is issued when the chip is Disconnected, the Paused status bit will be set by the 
chip, provided it has not already detected a Selection or Reselection. 
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5.5.4 SET ATN 

The Set ATN command causes ATN to be asserted immediately if the chip is connected as an Initiator. 
This command is invalid and ignored if issued when the chip is Disconnected or is operating in a Target 
role. The ATN signal is de-asserted in a Message Out phase when the transfer count becomes zero or 
one byte has been transferred (in a one-byte transfer command) during the execution of a Transfer Info 
command. 

The chip automatically sets ATN in two cases: 

1 . If a Select w/ATN command is issued and arbitration is won. 

2. If a parity error is detected on an input byte during execution of a Transfer Info command. 



5.5.5 MESSAGE ACCEPTED 

The Message Accepted command is an Immediate command that is valid only when connected as an 
Initiator. It is used after a Transfer Info or Pad command (See pages 29,30 TRANSFER INFO and 
TRANSFER PAD) to indicate to the chip that ACK can be de-asserted for the last byte. 

When an Initiator receives a message, a Transfer command is used. If the transfer is an input (I/O = 1) and 
the information is a message (MSG = 1, C/D = 1), the chip interrupts after receiving the last byte with 
a Function Complete interrupt. For this one special case, the chip also leaves ACK asserted on the bus. 
By interrupting and leaving ACK asserted, the chip gives the microprocessor a chance to interpret the 
message and set ATN, prior to ACK being de-asserted. This allows the chip to properly request a Message 
Out phase if the Initiator wants to send a "Reject Message" to the Target. 

Message Accepted must always be issued after a Transfer Info for a Message In phase, whether or not 
Set ATN is issued, in order to have the chip de-assert ACK. If the Initiator wants to reject the message, 
Set ATN would be issued first followed by Message Accepted. If the message is not to be rejected, only 
Message Accepted is issued. (Note: until Message Accepted is issued, the Target will not send 
another REQ since ACK is still asserted.) 



5.5.6 CHIP DISABLE 

Chip Disable immediately stops all chip operations and logically disconnects it from the circuit. All out- 
puts will be placed in a high impedance state and the chip will not respond to any commands (other than 
chip reset). The chip will also not respond to any activity on the SCSI bus. The only way to exit this 
condition is to activate the "reset" input or issue a Reset command. 
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5.5.7 SELECT w/ATN 

This command causes the chip to attempt to select a Target. It may only be used if the microprocessor 
is in the Disconnected state. Any attempt to issue this command in another state will result in an Invalid 
Command interrupt. Before issuing this command, the microprocessor must load the Transfer Counter 
for a timeout on the Target's response. This value is computed according to the following formula: 

Transfer Counter = Desired Timeout/ (1024 x Clock Period) 

If the Transfer Counter is loaded with the value zero, the chip will wait indefinitely for a response from the 
Target being selected. 

The microprocessor must also load the Destination ID Register with the three-bit code of the Target to be 
selected before issuing the Select w/ATN command. 

When the chip detects the Select w/ATN command, it begins by attempting to arbitrate for control of the 
SCSI bus. If, at any time during arbitration the chip becomes selected or reselected, the Select w/ATN 
is aborted and forgotten and the chip will interrupt with one of the following conditions: 

1. Selected 

2. Selected and Bus Service 

3. Reselected 

If arbitration is won, the chip places the SCSI bus in the Selection phase with ATN asserted, and uses 
the Destination ID Register to identify the desired Target. At the same time, the chip begins a timer based 
on the value computed above. If the Target does not respond within the timeout period, the chip will 
disconnect from the bus and interrupt with the Disconnected flag set in the Interrupt Register. (Note: 
The microprocessor should never monitor the Transfer Counter Zero flag in the Auxiliary Status Register 
to determine when a timeout has occurred.) If the Target responds within the allotted time, the chip will 
interrupt with a Function Complete status. Control of the SCSI bus then belongs to the selected Target 
and after the interrupt status has been read, another interrupt may occur indicating either that the Target 
has disconnected or is requesting a transfer. 

If the timeout is disabled and the Target does not respond, or if arbitration is not won, the only way to 
abort the Select w/ATN command is to issue the Pause command. After the Pause command is issued, 
it is still possible that the Function Complete or Disconnect interrupts may occur. This happens if one 
of the interrupts get set before the chip detects the Pause command, or if the Target responds while the 
chip is sequencing off the SCSI bus in a timeout condition. If the chip does not set either interrupt, it will 
set the Paused bit in the Auxiliary Status Register. If the microprocessor detects this bit after issuing the 
Pause command, then it is assured that the chip aborted the Select w/ATN command and no connection 
exists. 



5.5.8 SELECT w/0 ATN 

The Select w/o ATN is identical to the Select w/ATN command except that the ATN signal is not asserted 
during the Selection phase. 
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5.5.9 RESELECT 

This command causes the chip to attempt to reselect an Initiator. It may only be used if the micro- 
processor is in the Disconnected state. Any attempt to issue this command in another state will result 
in an Invalid Command interrupt. Before issuing this command, the microprocessor must load the 
Transfer Counter for a timeout on the Initiator's response. This value is computed according to the fol- 
lowing formula: 

Transfer Counter = Desired Timeout/ (1024 x Clock Period) 

If the Transfer Counter is loaded with the value zero, the chip will wait indefinitely for a response from the 
Initiator being reselected. 

The microprocessor must also load the Destination ID Register with the three-bit code of the Initiator to 
be reselected before issuing the Reselect command. 

When the chip detects the Reselect command, it begins by attempting to arbitrate for control of the 
SCSI bus. If, at any time during arbitration, the chip becomes selected or reselected, the Reselect is 
aborted and forgotten and the chip will interrupt with one of the following conditions: 

1. Selected 

2. Selected and Bus Service 

3. Reselected 

If arbitration is won, the chip places the SCSI bus in the Reselection phase using the Destination ID 
Register to identify the desired Initiator. At the same time, the chip begins a timer based on the value 
computed above. If the Initiator does not respond within the timeout period, the chip will disconnect 
from the bus and interrupt with the Disconnected flag set in the Interrupt Register. (Note: The micro- 
processor should never monitor the Transfer Counter Zero flag in the Auxiliary Status Register to 
determine when a timeout has occurred.) If the Initiator responds within the allotted time, the chip will 
interrupt with a Function Complete status. The chip (acting as the Target) is then in control of the SCSI 
bus, and waits for the Interrupt Register to be read by the microprocessor. After it has been read, the chip 
waits for a command from the microprocessor or ATN from the Initiator. If the ATN occurs, the chip 
will set the Bus Service interrupt. This interrupt may happen immediately after a command has been 
issued due to internal timing. In this case, the chip waits for the Interrupt Register to be read and the 
command is ignored. The chip then waits for a new command. 

If the timeout is disabled and the Initiator does not respond, or if arbitration is not won, the only way to 
abort the Reselect command is to issue the Pause command. After the Pause command is issued, it is 
still possible that the Function Complete or Disconnected interrupts may occur. This happens if one 
of the interrupts get set before the chip detects the Pause command, or if the Initiator responds while 
the chip is sequencing off the SCSI bus in a timeout condition. If the chip does not set either interrupt, 
it will set the Paused bit in the Auxiliary Status Register. If the microprocessor detects this bit after 
issuing the Pause command, then it is assured that the chip aborted the Reselect command and no 
connection exists. 
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5.5.10 DIAGNOSTIC (DATA TURNAROUND) 

This Interrupting command causes the chip to attempt to turn a data byte around through its internal 
data paths. When the command is loaded into the Command Register the Data Register Full bit is reset. 
The microprocessor then writes one byte into the Data Register. The chip moves the byte to another 
register and compares the contents of the Data Register. The byte is then moved to a third register (the 
SCSI output register) and good parity is generated if bit 6 of the command is off (0); bad parity is generated 
if bit 6 is on (1). Finally, the chip moves the byte back to the Data Register and compares it with the con- 
tents of the second register. Based on these comparisons and parity checking, the chip stores a result 
into the Diagnostic Status Register and sets the Function Complete interrupt. After reading the Interrupt 
Register, the microprocessor should make sure the Data Register Full bit is on (1)and read the contents 
of the Data Register. If the Data Register Full bit is not on (0), then an error has occurred. The following 
is a list of codes which are loaded into bits 6-3 of the Diagnostic Status Register as a result of this 
command. 



BIT 6543 RESULT 



0001 Data Miscompare (INITIAL) 

0010 Data Miscompare (FINAL) 

0011 Good Parity Detected 
0100 Bad Parity Detected 
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5.5.11 RECEIVE COMMANDS 

The Receive commands are Interrupting commands that are valid only when connected as a Target device. 
They are used by the Target to receive commands, data, and message information from an Initiator. 

The Receive commands transfer data; therefore, the Single Byte Transfer and DMA mode bits in the 
Command Register are valid for these commands. If the Single Byte Transfer bit is off (0), the Transfer 
Counter must be loaded before a Receive command is issued to the chip. In this case, the chip uses 
the Transfer Counter to determine the number of bytes to receive. 

When a Receive command is issued, the chip immediately resets the Data Register Full bit in the 
Auxiliary Status Register. The chip then drives the I/O, C/D, and MSG outputs for the proper information 
phase as follows. 

COMMAND NAME I/O C/D MSG 

Receive Command 
Receive Data 
Receive Message Out 
Receive Unspecified Info Out 

The chip then proceeds to request and receive the specified number of information byies. The DMA 
mode bit in the Command Register determines how the chip transfers these bytes from its Data Register 
to the microprocessor. 

When a Receive command is terminated, the chip generates an interrupt. The following two events 
can cause termination: 

1. The operation completes successfully; the Transfer Counter is zero. This event results in a Function 
Complete interrupt with the Parity Error bit in the Auxiliary Status Register off (0). If the initiator 
activated ATN during the operation, the Bus Service bit will also be on. 

2. A Parity Error occurs. The last byte transferred is the byte that caused the error. This event causes 
a Function Complete interrupt with the Parity Error bit in the Auxiliary Status Register on (1). If the 
Initiator activated ATN during the operation, the Bus Service bit will also be on. 

After any of the interrupts, the chip is always left in the connected Target state. The Transfer Counter 
indicates the number of bytes remaining to be transferred (zero if completed successfully, and the Data 
Register is empty (the last byte received is sent to the microprocessor). Also, ACK and REQ are inactive 
on the bus. 

(Note: if a Bus Service interrupt alone occurs after issuing a Receive command, the Initiator activated 
ATN before the chip began executing the command. In this case, the command is ignored by the chip.) 

A Receive command may be stopped prior to an interrupt causing event by issuing a Pause command. 
Operation of the Pause command is explained in an earlier section (See page 22, PAUSE). In the event 
the Initiator does not respond, or stops responding, the chip is left in a state where it cannot respond 
to a Pause command. For this case, a Disconnect command can be used to abort the command and 
the connection. The Disconnect command is explained in an earlier section (See page 22, DISCONNECT). 
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5.5.12 SEND COMMANDS 

The Send commands are Interrupting commands that are valid only when connected to the bus in the 
Target role. They are used by a Target to send status, data, and message information to an Initiator. 

The Send commands transfer data, and therefore, the Single Byte Transfer and DMA mode bits in the 
Command Register are valid for these commands. If the Single Byte Transfer bit is off (0), the Transfer 
Counter must be loaded before a Send command is issued to the chip. In this case, the chip uses the 
Transfer Counter to determine the number of bytes to send. 

When a Send command is issued, the chip immediately resets the Data Register Full bit in the Auxiliary 
Status Register. Therefore, the first byte of data for the transfer cannot be put into the Data Register until 
after a Send command is loaded into the Command Register. 

In executing a Send command, the chip drives the I/O, C/D, and MSG outputs for the proper information 
phase. These lines are logically driven for each Send command as shown below. 

COMMAND NAME I/O C/D MSG 

Send Status 

Send Data 

Send Message In 

Send Unspecified Info In 

After resetting Data Register Full and driving I/O, C/D, and MSG, the chip then proceeds to monitor 
Data Register Full, take the data from the Data Register, and send it to the Initiator. The DMA mode bit 
in the Command Register specifies how the data is loaded into the chip. 

After interrupting, the chip is left in the connected Target state, and ACK and REQ are inactive on the 
bus. When the transfer is complete, the chip interrupts with a Function Complete Interrupt. If the 
Initiator activated ATN during the transfer, a Bus Service bit will also beset by the chip. 

(Note: if a Bus Service interrupt alone occurs after issuing a Send command, the Initiator activated ATN 
before the chip began executing the command. In this case, the command is ignored by the chip.) 

A Send command may be stopped prior to an interrupt causing event by issuing a Pause command. 
Operation of the Pause command is explained in an earlier section (See page 22, PAUSE). In the event the 
Initiator does not, or stops responding, the chip is left in a state where it cannot respond to a Pause 
command. For this case, a Disconnect command can be used to abort the command and the connection. 
The Disconnect command is explained in an earlier section (See page 22, DISCONNECT). 
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5.5.13 TRANSFER INFO 

The Transfer Info command is an Interrupting command that is valid only when connected to the bus 
in the Initiator role. It is used by the Initiator for all information transfers across the SCSI bus. 

A Transfer Info command is issued by an Initiator in response to a Bus Service interrupt. The Bus Service 
interrupt, as explained in a previous section (See page 14, INTERRUPT REGISTER), is received by the 
connected Initiator upon the following conditions: receiving the first REQ from a Target, a previous 
command has completed and the Target changes phases, the Target changes phases before termination, 
or when a previous command has completed and the Target is requesting more information. It is not 
valid to issue a Transfer Info command without having a Bus Service interrupt, because the Target re- 
quests and controls all transfers. The chip will only permit one Transfer Info or Transfer Pad per Bus 
Service interrupt. 

After an Initiator receives a Bus Service interrupt, and prior to issuing a Transfer Info command, the I/O, 
C/D, and MSG bits from the Auxiliary Status Register (read prior to reading the Interrupt) should be ex- 
amined to determine the type of information phase and the direction of transfer requested by the 
Target. The Initiator then prepares for the transfer. If the Single Byte Transfer bit is not going to be set 
in the Command Register, the Transfer Counter must be loaded prior to issuing the Transfer Info com- 
mand. This is done in order to specify to the chip the maximum number of bytes to be transferred. 

When a Transfer Info is issued, the chip immediately resets the Data Register Full bit in the Auxiliary 
Status Register. For this reason, the first byte of data for an output operation cannot be loaded into the 
Data Register until after the command is loaded into the Command Register. The chip then proceeds 
with the transfer, expecting data to be read from (input), or written to (output), its Data Register as in- 
dicated by the DMA Mode bit in the Command Register. The chip automatically detects the direction of 
the transfer from the I/O bit which is stored in the Auxiliary Status Register. 

The chip continues a transfer until an interrupt causing event occurs. The following four events will 
cause the chip to terminate and interrupt. 

1. The maximum number of bytes specified have been transferred and the Target activated REQ or 
the Information Phase changed. This event results in a Bus Service Interrupt. Either single byte 
transfer was specified or the Transfer Counter is zero as indicated by a bit in the Auxiliary Status 
Register. The Target may or may not have changed the information phase type. The I/O, C/D, and 
MSG bits in the Auxiliary Status Register need to be examined at the time of the interrupt to determine 
what phase the Target is requesting. 

(Note: due to early notification of the phase change, a phase may be selected spuriously and not 
transfer any data. The microprocessor should not consider this an error condition.) 

2. The Target changes the information phase type before the maximum number of bytes are transferred. 
This event also causes a Bus Service interrupt. The new information phase may be determined by 
examining the I/O, C/D, and MSG bits in the Auxiliary Status Register. The Transfer Counter may be 
read at the time of the interrupt to determine the number of bytes remaining to be transferred. When 
this interrupt occurs for an output transfer, the chip may take one more byte from the microprocessor 
than it transfers, because of pre-fetching. However, the Transfer Counter still reflects the number 
of bytes remaining to be transferred. 

3. The Target releases the bus by dropping BSY. This event results in a Disconnected interrupt. 
Following this interrupt, the chip is no longer in the Initiator role. It now remains in the Disconnected 
state. 

4. The last byte of a Message Input phase has been received. This event results in a Function Complete 
interrupt. For this case, ACK is left active on the bus to allow the microprocessor to Set ATN for the 
purpose of rejecting the message. After this interrupt is received and a Set ATN is issued (if desired), 
a Message Accepted must be issued to turn off ACK for the last byte of the Message In phase. 
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For input transfers (I/O = 1), the chip checks parity for each byte received if the Parity Enable bit in the 
Control Register is on. When checking parity and the parity error occurs, the chip activates ATN prior to 
deactivating ACK for the byte that causes the error. It also turns on the Parity Error bit in the Auxiliary 
Status Register. The parity error, however, does not result in an interrupt. The chip waits for one of the 
four events listed above before interrupting. Therefore, the Parity Error bit should be examined when 
servicing any interrupt after issuing Transfer Info command for an input transfer. 

If ATN is asserted by the chip, either because of a parity error or because a SET ATN command is issued, 
the ATN will remain asserted until the end of the connection, or until a Message Out is transferred. 
Therefore, during each cycle of a Transfer Info operation for output, the chip checks for a message phase 
(C/D = 1, MSG = 1) and also either a single byte transfer or the Transfer Counter set at zero. If these 
conditions exist, the chip turns off ATN prior to activating ACK for the last byte of the message. 

As previously stated, a Transfer Info normally terminates with an interrupt. If a Transfer Info command 
must be aborted, possibly because of a timeout violation, either a Chip Reset or a Disconnect command 
can be used. It is noted, however, that although these commands will force the chip into a disconnected 
state, the Target device is left on the bus. A SCSI bus reset, which is not a chip function, is the only way 
an Initiator can force a Target to disconnect. 



5.5.14 TRANSFER PAD 

The Transfer Pad command is an Interrupting command that is valid only when connected to the bus as 
an Initiator. It is similiar to the Transfer Info command except that the data transfer between the chip 
and the microprocessor bus will be different. 

Transfer Pad can be used by an Initiator to continue handshaking with a Target without giving data to, 
or taking data from, the chip. This may be useful if the Target requests an invalid Information Transfer 
Phase. The chip operates in the same manner as it does for a Transfer Info command, except that for 
output transfers it takes only one byte of data from the microprocessor and sends the same byte repeat- 
edly until the transfer terminates. For input transfers, it accepts data from the SCSI bus but does not 
check parity or send it to the microprocessor. Though data is not exchanged with the microprocessor 
bus, the Transfer Counter is still used by the chip so that a maximum number of pad bytes can be specified. 

Protocol for using a Transfer Pad command is the same as the Transfer Info except that the DMA Mode 
bit has significance only for output transfers. The Transfer Pad terminates because of the same four 
events that cause a Transfer Info command to terminate. Also, similar to the Transfer Info command, 
Chip Reset and Disconnect can be used to abort the command. 
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SECTION 6 

BUS INITIATED FUNCTIONS 



6.1 SELECTION 

If the Select Enable bit in the Control Register is on, the chip may be selected by another SCSI device to 
be a TARGET for an I/O operation. Selection occurs in the chip only if all the following conditions exist: 
SELOUT = 0, BSYIN = 0, SELIN = 1, I/O = 0, the chip's ID bit is asserted by the selecting device on the 
data bus, no more than one other ID bit (the Initiator's) is asserted on the data bus and data bus parity 
is good. 

When all of these conditions exist, the chip is selected. It then encodes the Initiator's ID and loads it 
into bits 2-0 of the Source ID Register. The chip also detects whether or not the Initiator asserted its ID 
during selection, and either sets or resets the ID Valid bit in the Source ID Register. 

The chip then asserts BSYOUT, waits for SELIN to turn off, and proceeds to take one of the following 
actions as a result of being selected: 

1. If ATN is not asserted by the Initiator during selection, the chip generates a Selected interrupt 
indicating that the chip is connected as a Target. 

2. If ATN is asserted, the chip simultaneously generates Selected, and Bus Service interrupts, indicating 
that the chip is connected as a Target and ATN is asserted. 

6.2 RESELECTION 

If the Reselect Enable bit in the Control Register is on, the chip may be reselected by a SCSI Target 
device. Reselection occurs only if SELOUT = 0, SELIN = 1, BSYIN = 0, I/O = 1, the chip's ID bit and the 
Target's ID bit are asserted on the data bus, no other ID bits are asserted, and data bus parity is good. 

When all of these conditions exist, the chip is reselected. It then encodes the Target's ID and loads it into 
the Source ID Register. The chip also sets the ID Valid bit in the Source ID Register. 

The chip then asserts BSYOUT and waits for SELIN to be released by the Target. When the chip 
detects SELIN = 0, it de-asserts BSYOUT and then generates a Reselected interrupt. 

Reselection is now complete and the chip is in the connected Initiator state. 
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SECTION 7 

INITIALIZATION 



The SCSI device may be initialized by asserting RST for a period of at least 100ns, or by issuing a Chip 
Reset command to the device. The NCR 5385E will respond to the RST pulse or the Chip Reset 
command, by immediately disconnecting from the SCSI bus, initializing all storage elements and exe- 
cuting an internal self-diagnostic program. The self-diagnostic is explained in a previous section (See 
page 17, Diagnostic Status Register). The following table lists the status of all registers after the 
initialization procedure. 

7 6 5 4 3 2 10 

Data Register x x x x x x x x 

Command Register 

Control Register 

Destination ID Register 

Auxiliary Status Register x x x 1 

ID Register x x x 

Interrupt Register 

Source Register 111 

Diagnostic Status Register 1 x x x x x x x 

Transfer Counter (MSB) 

Transfer Counter (2nd) 

Transfer Counter (LSB) 

x = Unknown 
TABLE 7.1 REGISTER INITIALIZATION 



The controlling processor should loop on reading the Diagnostic Status Register until the Self-Diagnostic 
Complete bit (bit 7) is on (1). This should take approximately 350 clock cycles after reset occurs. The pro- 
cessor should then check the remaining bits in this register for all zeroes (no errors), and then load the 
Control Register enabling the proper bits to begin operation. The SCSI Protocol Controller is now 
connected to the SCSI bus in a disconnected state. It is ready to receive commands from the controlling 
processor or respond to (re) selection attempts. 
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SECTION 8 

EXTERNAL CHIP TIMING 

Timing requirements must be over the opera ting temperature (0-70°C) and voltage (4.75 to 5.25V) ranges. 
Loading for all output signals, exc ept S BEN, is assumed to be four low-power Schottky inputs, including 
50 pF capacitance. Loading for SBEN is assumed to be ten low-power Schottky inputs, including 
100 pF capacitance. 

8.1 MICROPROCESSOR INTERFACE 



8.1.1 CLK 
NAME 



DESCRIPTION 



MIN 



MAX 



UNITS 



tCP 
tCH 
tCL 


Clock Period 
Clock High 
Clock Low 


100 

.45 tCP 
.45 tCP 


200 

.55 tCP 
.55 tCP 


ns 



CLK 



t cp- 



/ S 



t]CH- 



t CL- 



X 



8.1.2 RESET 

NAME 



DESCRIPTION 



MIN 



TYP 



MAX 



UNITS 



tRST 


Reset Pulse Width 


100 






ns 



t RST- 



RST 



\ 
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8.1.3 MPU WRITE 



NAME 


DESCRIPTION 


MIN 


TYP 


MAX 


UNITS 


tASW 


Address Set-up Time 









ns 


tWR 


WR Pulse Width 


95 






ns 


tDW 


Data-toWRHigh 


50 






ns 


tAHW 


Address Hold Time 









ns 


tDHW 


Data Hold Time 


20 






ns 


tWCY 


WROfftoWRorRDOn 


125 






ns 



DACK 

CS.A0-A3 ) f 

WR 

D0-D7 



tAswte 



X 



t WR- 



X 



J 



tDW- 



AHW = 



X 



s£ tWCY- 



X 



N — ^ 



tDHW 



8.1.4 MPU READ 



NAME 


DESCRIPTION 


MIN 


TYP 


MAX 


UNITS 


tASR 


Address Set-up Time to RD 









ns 


tRD 


RD Pulse Width 


125 






ns 


tDR 


RD to Data 






90 


ns 


tAHR 


Address Hold Time 









ns 


tDHR 


Data Hold Time 


10 






ns 


tRCY 


RDOfftoWRorRDOn 


125 






ns 



DACK 
CS, A0-A3 
RD 
D0-D7 



X 



t ASRt< — 



X 



tRD' 



«=— tRCY— 5»|V 



X 



t DR- 



t ahr"> 



X 



t DHR 
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8.1.5 DMA WRITE 



NAME 


DESCRIPTION 


MIN 


TYP 


MAX 


UNITS 


tDCRQL 









40 


ns 


DACKtoDREQLow 


tDCW 


DACKtoWR 









ns 


tWR 


WR Pulse Width 


95 






ns 


tWDC 


WR High to DACK High 









ns 


tDHW 


Data Hold Time 


20 






ns 


tDW 


Data to WR High 


50 






ns 



cs 

DREQ 
DACK 

WR 
D0-D7 



f 



< t DCRQL- 



A 



> 



t DCW- 



H 



tWR- 



X 



r 



^ tDW- 



—C 

t WDC \^r- 



X 



tDHW 



8.1.6 DMA READ 

NAME 



DESCRIPTION 



MIN TYP MAX UNITS 



tDCRQL 









40 


ns 


DACKtoDREQLow 


tDCR 


DACK to RD 









ns 


tRD 


RD Pulse Width 


95 






ns 


tRDC 


RD High to DACK High 









ns 


tDHR 


Data Hold Time 


10 






ns 


tDR 


RD to Data 






80 


ns 



DREQ 

DACK 
RD 

D0-D7 
CS 



/ 



«= tDCRQL' 



\ 



I> 



tDCR 



^t 



tRD ^ 



X 



1 



t DR- 



— r 

tRDcfe- 



X 



tDHR 
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8.1.7 INTERRUPT 



NAME 


DESCRIPTION 


MIN 


TYP 


MAX 


UNITS 


t|R 


INTtoRD 









ns 


tRD 


RD Pulse Width 


95 






ns 


tRI 


RD High to INT Low 






125 


ns 


tlCY 


INT Off to INT On 


125 






ns 



INT 
RD 



A 



^t 



t RD< 



& 



tRI 5+=-tlCY-^J 
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8.2 SCSI INTERFACE 

8.2.1 SELECTION (INITIATOR) 



NAME 


DESCRIPTION 


MIN 


TYP 


MAX 


UNITS 


tBF 


Bus Free 


385 






ns 


tBIA(5) 


BSYINIowtoARBhigh 


1.2 




2.6 


us 


tSLA 


SELOUT high to ARB low & ID bit Disabled 


3.2 






us 


tBIBO(5) 


BSYIN low to BSYOUT high 


1.2 




2.8 


us 


tBCD 


Bus Clear Delay 






225 


ns 


tAD 


Arbitration Delay 


3.0 






us 


tpc 


Priority check to SELOUT 









ns 


tBID(5) 


BSYIN low to ID bit high 


1.2 




2.9 


us 


tADV 


Arbitration Data Valid to Priority Check 









ns 


tsi 


SELOUT to IGS 


2.0 






us 


tlDBL 


Target ID high to BSYOUT low 


1.1 






us 


tBOBI 


BSYOUT low to BSYIN low 







400 


ns 


tBSL 


BSYIN high to SELOUT low 


800 






ns 


tDID 


SBEN active to Bus enabled 


150 






ns 



NOTES: 

1. The chip ensures that the bus remains free (BSYIN and SELIN inactive) for tBF before 
attempting arbitration. 

2. If SELIN becomes active at any time during arbitration, the chip must deassert BSYOUT 
within tBCD. 

3. The chip waits (tAD), and then checks to see if arbitration is won (tPC). The chip then 
asserts SELOUT if arbitration is won. 

4. One of the data bits is assigned as an ID bit by the IDO-ID2 signals. During Bus Free, 
the chip places all of the data bits, including ID, in a high impedance state. During 
arbitration the chip enables its ID bit and drives it high, but the remainder of the data 
bits remain in the high impedance state for reading. 

5. To verify these timings in a test environment, the user must allow a minimum of 45 
clock cycles after the select command has been issued before the device begins to 
check for BSYIN low. 
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8.2.1 SELECTION (INITIATOR) 



ARB 



BSYIN \^ 



BSYOUT SS^ 
SELIN ^\ 

SELOUT 



■tBFA' 



/ 



© 

t BF 



WW 



tBFBO- 






tBID- 



\. 



■tAD> 

® 



SB(ID) '////, >NP"T) "////b -S 



(Z) j<5 tBFID > 



t PC 



/ 



t SLA 



\J 



SBO-7, SBP ^y/oNPUT), //////Y^l^Jnput) W^^target id (output) $%% 



(Except ID) 
IGS 

TGS 

ACK 

ATN 
SBEN 



t ADV- 



(INPUT) 



(INPUT) 



ke-tsi 



r 






V 



r* 



V 



•t IDBL 



tBSL-> 



V 



^m. 



t IAH 



tDID 



(OUTPUT) 



(OUTPUT) 



4- tDID 
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8.2.2 SELECTION (TARGET) 



NAME 


DESCRIPTION 


MIN 


TYP 


MAX 


UNITS 


TSBI 


SELINhightoBSYINlow 


50 






ns 


tlDBI 


ID'S valid to BSYIN low 









ns 


tlOBI 


1/OlowtoBSYINIow 









ns 


tBIBO 


BSYIN low to BSYOUT high 







2.0 


us 


tBODH 


BSYOUT high Data Hold 









ns 


tBOSH 


BSYOUT high SELIN Hold 









ns 


tASI 


ATNhightoSELINlow 









ns 


tsio 


SELIN low to Phase signals Enabled 


150 






ns 


tOT 


Phase signals enabled to TGS High 


150 






ns 


tDBD 


SBEN low to Data Bus Enabled 


150 






ns 



ARB 
BSYIN 
BSYOUT 
SELIN 



\ 



/ 



t SBi — =* t BIBO 



5>| t IDBI 

S bq.7,sbp V777777?) ( 



r 



t BOSH- 



A 



INITIATOR & 
TARGET ID'S 



TGS 
IGS 
I/O 
ATN 



WWWW^I 



t IOBI 



t BODH fe— 

(INPUT) V/// ,nput ///»-< 



(INPUT) 



E 



ASI& 



tSI0 



<- 



^< 



/ 



I t0T 



OUTPUT 



c/d.msg ////////////// >»$r777777777T7> r^ 



SBEN 



t DBD 



\. 
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8.2.3 RESELECTION (INITIATOR) 



NAME 


DESCRIPTION 


MIN 


TYP 


MAX 


UNITS 


tSBI 


SELINhightoBSYINlow 


50 






ns 


tlDBI 


ID'S valid to BSYIN low 









ns 


tlOBI 


1/OhightoBSYINIow 









ns 


tBIBO 


BSYIN low to BSYOUT high 







2.0 


^s 


tBODH 


BSYOUT high Data Hold 









ns 


tBOSH 


BSYOUT high SELIN Hold 









ns 


tBOIH 


BSYOUT high I/O hold 









ns 


tSIBO 


SELIN low to BSYOUT low 









ns 


tSAA 


SELIN low to ACK & ATN enabled 


750 






ns 


tAAl 


ACK & ATN enabled to IGS high 


150 






ns 


t|DB 


1/OlowtoSBEN low 









ns 


tDBD 


SBEN low to Data Bus Enabled 


150 






ns 



ARB 
BSYIN 

BSYOUT 
SELIN 



\ 



/ 



tSBI- 



t IDBlSlj 



t BIBO 



/ 



■t BOSH— 5>jt SIBO 

V 



IV 



SBO-7, SBP ///////X tS?dV (i 



TGS 
IGS 



t IOBI 



"° //////// 

ATN 

ACK 



I* •*" 



t BODH|<$- . 



|«S- tDBDiJ 



t BOIH |^- 



N 



(INPUT) 



(INPUT) 



SBEN 



il 



JZ± 



^-t SAA 

-A 



tAAl 



(OUTPUT) 



(OUTPUT) 



K 



t IDB. 
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8.2.4 RESELECTION (TARGET) 



NAME 


DESCRIPTION 


MIN 


TYP 


MAX 


UNITS 


tBF 


Bus Free 


385 






ns 


tBIA(5) 


BSYINIowtoARBhigh 


1.2 




2.6 


us 


tSLA 


SELOUT high to ARB low & ID bit Disabled 


3.2 






us 


tBIBO(5) 


BSYIN low to BSYOUT high 


1.2 




2.8 


us 


tBCD 


Bus Clear Delay 






225 


ns 


tAD 


Arbitration Delay 


3.0 






us 


tpc 


Priority check to SELOUT 









ns 


tBID(5) 


BSYIN low to ID bit high 


1.2 




2.9 


us 


tADV 


Arbitration Data Valid to Priority Check 









ns 


tso 


SELOUT Phase signals Enabled & SBEN Low 


2.4 






us 


tOT 


Phase Signals Enabled to TGS High 


150 






ns 


tDID 


SBEN low to Bus Enabled 


150 






ns 


tlDBL 


INITIATOR ID high to BSYOUT low 


2.7 






us 


tBOBI 


BSYOUT low to BSYIN 







400 


ns 


tBIBO 


BSYIN high to BSYOUT high 


0.7 




2.0 


us 


tBSL 


BSYOUT high to SELOUT low 


450 






ns 



NOTES: 

1. The chip ensures that the bus remains free (BSYIN and SELIN inactive) for TBF before 
attempting arbitration. 

2. If SELIN becomes active at any time during arbitration, the chip must deassert BSYOUT 
within tBCD. 

3. The chip waits ^AD), and then checks to see if arbitration is won (tPC). The chip then 
asserts SELOUT if arbitration is won. 

4. One of the data bits is assigned as an ID bit by the IDO-ID2 signals. During Bus Free, 
the chip places all of the data bits, including ID, in a high impedance state. During 
arbitration the chip enables its ID bit and drives it high, but the remainder of the data 
bits remain in the high impedance state for reading. 

5. To verify these timings in a test environment, the user must allow a minimum of 45 
clock cycles after the select command has been issued before the device begins to 
check for BSYIN low. 
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8.2.4 RESELECTION (TARGET) 



ARB 



bsyin M\ WUM 



BSYOUT ^ 
SELIN « 



SELOUT 



tBIA 



V 



© 



tBF 



tBIBO 



/ 



^W t BCD fs£- 



tAD- 



tPL 



t BID 



r 



tg tSLA 



V 



tlDBL >* 



SB(ID) W Mi&™?M//////> -' <°"tput) v_y| Wfc 

© fc— tBID — =J I I 

SB0 - 7 - ^m^Mmm^^mmm^^m 

' tADV>| 



(Except I 
TGS 



VALID 



tso 






|^ t BOBI 



BIBO 



tBSL: 



A_ 



C— ' t.0T 



OUTPUT 



SBEN 



^ 



(OUTPUT) 



tDID 



^ 
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8.2.5 INFORMATION TRANSFER PHASE INPUT (INITIATOR) 



NAME 


DESCRIPTION 


MIN 


TYP 


MAX 


UNITS 


tDVRH 


Data Valid to REQ high 









ns 


tjZJRI 


Phase Valid to REQ high 


100 






ns 


tRAH 


REQ high to ACK high 









ns 


tRAL 


REQ low to ACK low 









ns 


tAA 


ATN high to ACK low 


100 






ns 


tS0 

t0H 


SELIN low to Phase change 









ns 


Phase hold from ACK low 


20 






ns 


tADH 


Data hold from ACK high 









ns 


tARL 


ACK high to REQ low 


35 






ns 


tlODB 
tDZDB 


I/O high to SBEN high 






50 
10 


ns 
ns 


Data Bus disable from SBEN high 


tARH 


ACK Low to REQ High 


35 






ns 



NOTE 1 : If the chip detects a parity error it must assert ATN at least tAAbefore it de-asserts ACK. 



REQ 

ATN 
ACK 






< t DVRH 



sbo-7. S&P 7M77///M ( 

\^ — t DZDB 



SELIN 3X 
BSYIN 



IGS 
TGS 

I/O 
C/D 
MSG 
SBEN 

ARB 



^ 



7 



■tlODB 



t RAH 



© 



/ 



J 



\ 



tRAL- 
tARL 



*StADHH 



/ 



I- 

t0H 



V 



«Z. t AA 



VALID DATA (INPUT) 



WMMMK 



tS0 

< t0RI 



t ARH" 



m 



m 



X 
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8.2.6 INFORMATION TRANSFER PHASE INPUT (TARGET) 

NAME DESCRIPTION MIN TYP MAX UNITS 



tsd 

t0RO 

tRAH 

tARL 

tDVA 

tRAL 

tARH 

tRLDH 

t0HA 

tDBIO 

tDZDB 


SELIN low to Phase Change 
Phase Change to REQ out 
REQ high to ACK high 
ACK high to REQ low 
Data Valid to ACK high 
REQ low to ACK low 
ACK low to REQ high 
REQ low Data Hold 
Phase Hold from ACK low 
SBEN high to I/O low 



500 

35 



35 











ns 
ns 
ns 
ns 
ns 
ns 
ns 
ns 
ns 
ns 
ns 


Data Bus disable to SBEN high 



REQ 
ACK 
ATN 



t0RO' 



mm 



SB0-7,SBP" ) 



SELIN 

BSYOUT 

TGS 

I/O 

C/D 

MSG 

SBEN 

ARB 



\ 



2S2 



^.L 



SS^ 



5S 



37 



U 



RAH" 



J 



J<-t DVA 

" ( VALID 



t ARL =4^- t RAL 



V 



\ 



'//////////7777777/////////m7777777 



Sz 



iwnnm 



SL 



tS0 



c 

tARH te— 



t RLDH 



• tpHA 

V7777T / 



5C 



I*- t 



WML 



DBIO 



t DZDB 
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8.2.7 INFORMATION TRANSFER PHASE OUTPUT (INITIATOR) 



NAME 


DESCRIPTION 


MIN 


TYP 


MAX 


UNITS 


t0RI 


Phase Valid to REQ high 


100 






ns 


tRAH 


REQ high to ACK high 


35 






ns 


tRAL 


REQ low to ACK low 









ns 


tDVA 


Data Valid to ACK high 


100 






ns 


tRLDH 


REQ low Data hold 









ns 


t^H 


Phase hold from ACK low 


20 






ns 


tARL 


ACK high to REQ low 









ns 


tlODB 


1/OlowtoSBEN low 









ns 


tDBE 


SBEN low to Data Bus Enable 


85 






ns 


tDBA 


SBEN low to ACK high 


185 






ns 


tRATL 


REQ High to ATN low 









ns 


tATLA 


ATN Low to ACK High 


25 






ns 


tARH 


ACK Low to REQ High 


35 






ns 



NOTE 1 : ATN is only de-asserted in this manner during the last byte of a Message Out Phase. 



1 



REQ 
ATN 
ACK 



y 



SB0-7,SBPZ222ZZ> 

BSYIN 

IGS 

TGS 

I/O SJ 

c/d 5S^ 



MSG S)< 



SBEN 
ARB 



t DBE 



t 0RI 



®A 



tRATL 



tRAH > 



tDVA- 
<• tATLA 



X 



tARL 



tRAL 



t0H 



tARH 



\ 



<//////X VALID DATA 



tRLDH }<~ 

ZZZMZHK 



tDBA 



K 



m. 



UK 



X 



t IODB 



z 
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8.2.8 INFORMATION TRANSFER PHASE OUTPUT (TARGET) 



NAME 



DESCRIPTION 



MIN TYP MAX UNITS 



tS0 

tlODB 

tDBR 

tDVA 

tRAH 

tARL 

tRAL 

tARH 

t0HA 

tADH 

tDBE 


SELIN low to Phase Change 
I/O high to SBEN low 
SBEN lowtoREQout 
Data Valid to REQ high 
REQ high to ACK high 
ACK high to REQ low 
REQ low to ACK low 
ACK low to REQ high 
Phase hold from ACK low 
Data hold from ACK low 
SBEN low to Data Bus Enabled 




500 

185 

100 













85 






ns 
ns 
ns 
ns 
ns 
ns 
ns 
ns 
ns 
ns 
ns 



REQ 
ACK 
ATN 



\\\\\\\\\\\\\^^^^ 



SBO-7, SBP \ \\\\\\\\TO pC 

SELIN "\ -^1 tDBE k- 

BSYOUT 
TGS 
I/O 
C/D 



1M 



MSG ~SM 



t DBR 



tDVR <■ tRAH*=* tARLT^-t 

/ 



Z 



RALH t ARH \^~ 

~A 



— H |^~tADH 

A 



t SCjf 



— t0HA 

|\£££ 






SBEN 
ARB 



\ 



tlODB 
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8.2.9 BUS RELEASE FROM SELECTION (INITIATOR) 



NAME 


DESCRIPTION 


MIN 


TYP 


MAX 


UNITS 


tTOD 
tlDOD 
tSOD 
tDOS 


Bus Release Timeout Delay 
IGS&SBEN Turn-off Delay 
SELOUT Turn-off Delay 


100 









MS 

ns 
ns 
ns 


Driver Turn-off set-up to IGS & SBEN off 



NOTE 1: If the chip detects BSYIN active by the end of the timeout delay, the bus release sequence 
shall be aborted since selection has been successful. 



BSYIN 






© 




////JJ//W/WW/////J/}. 


BSYOUT 








SELIN 




\ 


SELOUT 


<— t IDOD — 5> 


t SOD 


\ 


IGS 


(2 ID 




. t tod 
OUT 




-^ t nn« 






-*j 


-* 










. 


IN 


SBO-7 SBP 


i 
S 


\ 












OUT 






( 


IN 


ATN 


f 


\ 


















( 


IN 


ACK 


/ 


\ 
















SBEN 






/ 





ARB 
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8.2.10 BUS RELEASE FROM RESELECTION (TARGET) 



NAME 


DESCRIPTION 


MIN 


TYP 


MAX 


UNITS 


tTOD 
tDOD 
tSOD 
tDOS 


Bus Release Timeout Delay 
TGS & SBEN Turn-off Delay 
SELOUT Turn-off Delay 


100 









us 
ns 
ns 
ns 


Driver Turn-off set-up to TGS & SBEN off 



NOTE 1: If the chip detects BSYIN active by the end of the timeout delay, the bus release sequence 
shall be aborted since reselection has been successful. 



BSYIN 


U> 


////////////////////////////, 


BSYOUT 












SELIN 






\ 






SELOUT 




^ t TDOD — => 


t SOD UL_ ■■ " 


TGS 






\ 




1^ "iTOU " -* 

OUT (ID'S) \ OUT 


"> 


t DOS 


< 






SBO-7, SBP 


r 
S 














OUT 




i IM 


I/O 


> 


\ IN 


MSG,C/D 


OUT 




( IN 


OUT 




J 




REQ 


— ( IN 








SBEN 
ARB 


/ 









48 



8.2.11 BUS RELEASE FROM INFORMATION PHASE (INITIATOR) 



NAME 


DESCRIPTION 


MIN 


TYP 


MAX 


UNITS 


t|DB 
tDOS 









225 


ns 
ns 


IGS & SBEN Turn-off Delay from BSYIN off 
Driver Turn-off set-up to IGS off 



BSYIN 

BSYOUT 

SELIN 

SELOUT 

IGS 



SBEN 



ARB 



V 



«= t IDB 



SBO-7, SBP OUT or IN 
ATN _ 
ACK 



OUT 



OUT 



\ 



2n 
2r 



DOS 



DOS 



DOS 



< 



^V 



■v 



T 



IN 



IN 



IN 
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8.2.12 BUS RELEASE FROM INFORMATION PHASE (TARGET) 



NAME 


DESCRIPTION 


MIN 


TYP 


MAX 


UNITS 


tTDB 
tDOS 









225 


ns 
ns 


TGS & SBEN Turn-off from BSYOUT off 
Driver Turn-off set-up to TGS off 



BSYIN 

BSYOUT 

SELIN 

SELOUT 

TGS 



I/O, C/D 
MSG 



SBEN 
ARB 



\ 



K 



SBO-7, SBP out or IN 
REQ — 



OUT 



OUT 



t TDB 



I 



2r 



tlDOS 



DOS 



"^ 



t DOS 



< 



X. 



"V 



/ 



IN 



IN 
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NCR 



NCR Microelectronics Division 
1635 Aero plaza Drive 
Logic Products Marketing 
Colorado Springs, CO 80916 
(303) 596-5612 or (800) 525-2252 
TELEX 45-2457 
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